package edu.nf.exam.dao;

import edu.nf.exam.entity.SubjectInfo;
import org.apache.ibatis.annotations.Param;

import java.util.List;

/**
 * @Author : QYM
 * @create 2021/6/17
 *  学科信息表--接口
 */
public interface SubjectInfoDao {
    /**
     * 添加学科
     * @param subjectInfo
     * @return
     */
    int addSubject(SubjectInfo subjectInfo);

    /**
     * 删除学科
     * @param subjectId
     * @return
     */
    int delSubject(Integer subjectId);

    /**
     * 修改学科
     * @param subjectInfo
     * @return
     */
    int updateSubject(SubjectInfo subjectInfo);

    /**
     * 模糊查询学科
     * @param levelName
     * @param pageNum
     * @param pageSize
     * @return
     */
    List<SubjectInfo> queryByLikeSubject(@Param("levelName") String levelName,
                                             @Param("pageNum") Integer pageNum,
                                             @Param("pageSize") Integer pageSize);

    /**
     * 根据ID查询学科
     * @param subjectId
     * @return
     */
    SubjectInfo queryByIdSubject(@Param("subjectId") Integer subjectId);

    /**
     * 去重查询年级
     * @return
     */
    List<SubjectInfo> selectLevelNameByDistinct();

    /**
     * 多条件查询
     * @param subjectInfo
     * @return
     */
    List<SubjectInfo> selectByMore(SubjectInfo subjectInfo);

    /**
     * 根据学科名称和年级查询，服务于判断学科创编和修改是否唯一
     * @return
     */
    int queryByNameSubject(@Param("subjectName")String subjectName,
                           @Param("levelName")String levelName);
}
